<?php
//------------------------------------------------------------ Contraintes d'accès de la page

	// on vérifie que cette page est appelée à partir de l'index et que l'utilisateur a le droit d'édition
	if(isset($_SESSION) && ($GLOBALS['USER']['level'] >= 4 || $GLOBALS['USER']['admin'])){

		// l'identifiant de la donnée à supprimer est indiqué par un entier
		if(isset($_GET['id']) && numericInt($_GET['id'])){
		
			$nb_familles = valueExists((int)$_GET['id'], "CODEFAMILLE", "famille", $connexion);
			
			if($nb_familles == 1){ // la famille à éditer existe et son identifiant est unique
	
?>
<?php
//------------------------------------------------------------ Valeur des champs avant saisie

	// récupération des informations de la famille
	$query_recuperation_famille = "SELECT NOMFAMILLE, CODEAUTEUR ";
	$query_recuperation_famille .= "FROM famille ";
	$query_recuperation_famille .= "WHERE CODEFAMILLE = ".$_GET['id']." ";
	
	$result_recuperation_famille = mysql_query($query_recuperation_famille, $connexion) or logError("RECUPERATION FAMILLE-".$query_recuperation_famille."-".mysql_error());
	
	$tab_recuperation_famille = mysql_fetch_row($result_recuperation_famille);

	$dv_nom = $tab_recuperation_famille[0]; // valeur du champ nom (edt_nom)
	$dv_auteur = $tab_recuperation_famille[1]; // valeur du champ auteur (edt_nom)
	
	$nomOrigine = $tab_recuperation_famille[0];
	
	mysql_free_result($result_recuperation_famille);
	
	// valeurs possibles du champ edt_auteur
	$query_recuperation_auteurs = "SELECT CODEAUTEUR AS id, ABREVIATIONAUTEUR AS abreviation FROM auteur ORDER BY abreviation";
	
	$result_recuperation_auteurs =  mysql_query($query_recuperation_auteurs, $connexion) or logError("RECUPERATION AUTEURS-".$query_recuperation_auteurs."-".mysql_error());

	$selectAuteurs = array(); // on créé un tableau qui contient la liste des auteurs ainsi que les informations de chacun
	$nb_auteurs = 0;
	while($tab_recuperation_auteurs = mysql_fetch_assoc($result_recuperation_auteurs)){
		$selectAuteurs[$nb_auteurs] = $tab_recuperation_auteurs;
		$nb_auteurs++;
	}
	
	mysql_free_result($result_recuperation_auteurs);
	
?>
<?php
//------------------------------------------------------------ Traitements si le formulaire a été envoyé

/********************************* Règles :

	- le nom de la famille ne peut pas être vide
	- le nom de la famille ne doit pas être déjà enregistré dans la BDD
	- l'auteur doit exister dans la BDD
	
*****************************************/

	$statut = array(); // indique le statut du traitement du formulaire (echec ou succes) - tableau contenant les messages à afficher
	$erreur = false; // indique si une erreur a été rencontrée lors du traitement

	trimTabByKey($_POST, "edt_"); // appel à la fonction trimTabByKey() définie dans fonctions.php
	
	//---------------------------------- Contrôle des données ----------------------------------
	
	if(isset($_POST['form_sent'])){ // si le formulaire est envoyé
	
		// Contrôle des données du nom de la famille
		if(isset($_POST['edt_nom']) && is_string($_POST['edt_nom'])){
			if(emptyString($_POST['edt_nom'])){
				$statut[] = "Le nom de la famille ne peut être effacé";
				$erreur = true;
			}else{
				if(!strcmpCollation($_POST['edt_nom'], $nomOrigine)){ // Si le nom a été modifié
					if(valueExists($_POST['edt_nom'], "NOMFAMILLE", "famille", $connexion) > 0){
						$statut[] = "Cette famille existe déjà";
						$erreur = true;
					}else{
						$dv_nom = $_POST['edt_nom'];
					}
				}else{
					$dv_nom = $_POST['edt_nom'];
				}
			}
		}else{
			$statut[] = "Aucun nom de la famille indiqué";
			$erreur = true;
		}
		
		// Contrôle des données de l'auteur ayant découvert la famille
		if(isset($_POST['edt_auteur']) && is_string($_POST['edt_auteur'])){
			if(!numericInt($_POST['edt_auteur'])){
				$statut[] = "Format de l'auteur de la famille incorrect";
				$erreur = true;
			}else{
				if(valueExists((int)$_POST['edt_auteur'], "CODEAUTEUR", "auteur", $connexion) == 1){
					$dv_type = $_POST['edt_auteur'];
				}else{
					$statut[] = "L'auteur indiqué n'existe pas";
					$erreur = true;
				}
			}
		}else{
			$statut[] = "Aucun auteur de la famille indiqué";
			$erreur = true;
		}
		
		//---------------------------------- Modification de la famille ----------------------------------
	
		if(!$erreur){ // aucune erreur n'a été rencontrée jusqu'ici
		
			$query_modif_famille = "UPDATE famille ";
			$query_modif_famille .= "SET NOMFAMILLE = ".mysqlString($_POST['edt_nom']).", CODEAUTEUR = ".$_POST['edt_auteur']." ";
			$query_modif_famille .= "WHERE CODEFAMILLE = ".$_GET['id']." ";
			
			$result_modif_famille = mysql_query($query_modif_famille, $connexion) or logError("MODIFICATION FAMILLE-".$query_modif_famille."-".mysql_error());
		
			if($result_modif_famille === true){
				$statut[] = "Les informations de la famille ont été modifiées";
				logAction("FAMILLE (id: ".$_GET['id'].") MODIFIEE par ".capitalise($GLOBALS['USER']['prenom'])." ".mb_strtoupper($GLOBALS['USER']['nom'])." (".$GLOBALS['USER']['login'].")");
			}else{
				$statut[] = "Erreur critique lors de la modification de la famille";
				$erreur = true;
			}
		
		}
		
	}
?>
<?php
//------------------------------------------------------------ Affichage du statut si le formulaire a été envoyé

	if(isset($_POST['form_sent'])){ // si le formulaire est envoyé
		
		if($erreur){
			afficherStatut($statut, 3); // appel à la fonction afficherStatut() définie dans fonctions.php
		}else{
			afficherStatut($statut, 1); // appel à la fonction afficherStatut() définie dans fonctions.php
		}
	
	}

?>
<?php
	boutonRetour("index.php?p=gestion/famille_gere"); // // appel à la fonction boutonRetour() définie dans fonctions.php
?>
<form method="post" action="index.php?p=gestion/famille_edite&amp;id=<?php echo $_GET['id']; ?>">
	<table class="formulaire" style="margin-left: auto; margin-right: auto;">
		<tr>
			<th class="titre" colspan="2">Modification des informations d'une famille</th>
		</tr>
		<tr>
			<td style="width: 120px" class="etiquette">Nom * :</td>
			<td style="width: 375px" class="champ"><input type="text" name="edt_nom" size="25" value="<?php echo htmlentities($dv_nom, ENT_COMPAT, "UTF-8"); ?>" /></td>
		</tr>
		<tr>
			<td class="etiquette">Auteur/Groupe * :</td>
			<td class="champ">
				<select id="edt_auteur" name="edt_auteur" style="width: 200px;">
               <option>
					<?php
						if($nb_auteurs > 0){
							foreach($selectAuteurs as $auteur){
								if($auteur['id'] == $dv_auteur){
									echo "<option value=\"".$auteur['id']."\" selected=\"selected\">".htmlentities($auteur['abreviation'], ENT_NOQUOTES, "UTF-8")."</option>";
								}else{
									echo "<option value=\"".$auteur['id']."\">".htmlentities($auteur['abreviation'], ENT_NOQUOTES, "UTF-8")."</option>";
								}
							}
							unset($auteur);
						}else{
							echo "<option disabled=\"disabled\">Aucun auteur enregistré</option>";
						}
					?>
				</select>
				<input type="text" class="recherche" id="srch_auteur" value="recherche..." size="10" onfocus="clearField('srch_auteur', 'recherche...');" onblur="resetField('srch_auteur', 'recherche...');" onkeyup="trierSelect('edt_auteur', 'srch_auteur');" /><br />
				<input type="button" value="Ajouter un auteur/groupe" onclick="popup('popup.php?p=gestion/auteur_ajoute_popup&amp;maj=edt_auteur&amp;sel=1', 500, 420);" />
			</td>
		</tr>
		<tr>
			<td class="envoi" colspan="2"><input type="submit" value="Modifier" /><input type="hidden" name="form_sent" value="1" /></td>
		</tr>
		<tr>
			<td class="legende" colspan="2">* = champs obligatoires</td>
		</tr>
	</table>
</form>
<div class="information">
	<div class="titre">Informations</div>
	<h4>Auteur / Groupe d'auteurs :</h4>
	<p>Indique l'auteur ayant mis en évidence la famille. Si plusieurs auteurs ont découvert la famille ensemble, indiquez-les en un seul champ (plus d'informations en ajoutant les auteurs).</p>
</div>
<?php
//------------------------------------------------------------ Accès refusé à la page

			}else{
				afficherStatut("La famille à éditer n'existe pas", 3); // appel à la fonction afficherStatut() définie dans fonctions.php
			}

		}else{
			afficherStatut("La famille à éditer n'est pas ou mal indiquée", 3); // appel à la fonction afficherStatut() définie dans fonctions.php
		}

	}else{
		if(isset($_SESSION)){
			if(!isset($_SESSION['user_id'])){ // si l'utilisateur n'est pas connecté
				include("pages/connexion.php");
			}else{ // si l'utilisateur est connecté et qu'il n'a pas accès à la page, c'est qu'il n'a pas le droit d'utilisation nécessaire
				include("pages/401.htm");
			}
		}
	}

?>